package com.ciaojian.core.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ciaojian.core.enums.business.MaterialApplyRecordStatusEnum;
import com.ciaojian.core.model.MaterialApplyRecord;
import com.ciaojian.core.model.MaterialApplyRecordMaterial;
import com.ciaojian.core.model.dto.MaterialApplyRecordDTO;
import com.ciaojian.core.model.dto.MaterialApplyRecordMaterialDTO;
import org.apache.ibatis.annotations.*;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * <p>
 * 物资申请记录 Mapper 接口
 * </p>
 *
 * @author Atlakyn
 * @since 2021-07-05
 */
public interface MaterialApplyRecordMapper extends BaseMapper<MaterialApplyRecord> {
    /**
     * 查找全部物资申请列表
     *
     * @param franchiseesId 加盟商 ID
     * @param status 状态
     * @param page   分页插件
     * @return 物资申请列表
     */
    List<MaterialApplyRecordDTO> findAllApplyRecord(
            @Param("franchiseesId") Integer franchiseesId,
            @Param("status") MaterialApplyRecordStatusEnum status,
            @Param("page") Page<MaterialApplyRecordMaterialDTO> page);

    /**
     * 按申请发型师和门店查找物资申请列表
     *
     * @param storeId  门店 ID
     * @param workerId 发型师 ID
     * @param status   状态
     * @param page     分页插件
     * @return 物资申请列表
     */
    List<MaterialApplyRecordDTO> findApplyRecord(@Param("storeId") Integer storeId,
                                                 @Param("workerId") Integer workerId,
                                                 @Param("status") MaterialApplyRecordStatusEnum status,
                                                 @Param("page") Page<MaterialApplyRecordMaterialDTO> page);


    /**
     * 根据 ID 查询
     *
     * @param id id
     * @return 物资申请记录
     */
    @Select("SELECT * FROM d_material_apply_record_material WHERE id = #{id} ")
    MaterialApplyRecordMaterial getById(@Param("id") Integer id);


}
